package qjc.n_贪心算法;

import java.util.ArrayList;
import java.util.List;

public class n4_划分字母区间 {
    /**
     * 记录每个字母最后出现的位置，分别记录开始边界和结束边界
     *
     * @param s
     * @return
     */
    public List<Integer> partitionLabels(String s) {
        int[] sNums = new int[26];
        for (int i = 0; i < s.length(); i++) {
            sNums[s.charAt(i) - 'a'] = i;
        }
        int start = 0;
        int end = 0;
        List<Integer> res = new ArrayList<>();
        for (int i = 0; i < s.length(); i++) {
            end = Math.max(end, sNums[s.charAt(i) - 'a']);
            if (i == end) {
                res.add(end - start + 1);
                start = i + 1;
            }
        }
        return res;
    }
}
